

*O*  
*a*

~~METHOD AND APPARATUS FOR RAPID DATA TRANSFER BETWEEN  
DIS-SIMILAR DEVICES~~

Background of the Invention

5 This invention relates to test instruments, and more particularly to a network test instrument.

In testing and analysis of networks, as network speeds increase, more efficient use of test instrument processing capabilities becomes important, to maximize 10 analysis abilities and minimize hardware requirements. Therefore, it is desirable to move data on a bus only a single time, if possible. In network analysis instruments, various specialized processing chips may be employed, however, not all the desired devices in 15 use in the instrument to which data may be destined behave similarly in receiving data. Thus, for example, at gigabit data transfer rates, there may not be sufficient time to employ multiple storing and retrieval of data to separate devices.

20

Summary of the Invention

In accordance with the invention, a method and apparatus is provided to transfer data between dissimilar devices.

25 Accordingly, it is an object of the present invention to provide an improved apparatus for minimizing the time to retrieve and store data in external memory and internal processor memory.

It is a further object of the present invention to 30 provide an improved apparatus that stores data from a media access controller simultaneously in memory and in a DSP microprocessor.

The subject matter of the present invention is particularly pointed out and distinctly claimed in the 35 concluding portion of this specification. However,

000626074627US

both the organization and method of operation, together with further advantages and objects thereof, may best be understood by reference to the following description taken in connection with accompanying drawings wherein like reference characters refer to like elements.

Brief Description of the Drawings

FIG. 1 is a block diagram of a network test instrument embodying the invention; and

FIG. 2 is a timing diagram of operations according to the invention.

Detailed Description

The system according to a preferred embodiment of the present invention comprises a network test instrument adapted to speed operations by providing data from one source to two destinations substantially simultaneously.

Referring to FIG. 1, a block diagram of a network test device 10, the device connects to a network 12 via a media access controller (MAC) 14. The MAC is connected via a bus 16 to memory 18 (suitably SDRAM) and a digital signal processor (DSP) microprocessor 20. A complex programmable logic device (CPLD) 22 communicates to each of the MAC 14, the memory 18 and the DSP 20, providing control.

In operation, traffic from the network is received via the media access controller 14. The media access controller is a first-in first-out (FIFO) device and does not provide addressed access to or output for the data it receives. On the other hand, both the SDRAM 18 and the DSP microprocessor 20 employ addressing schemes for storage of data.

Typically, in accordance with the prior art, data received from the MAC would be read by the DSP via the

00000000-0000-0000-0000-000000000000

bus, and, if the data was to be stored, it would be written to the SDRAM via the bus by the DSP in a separate bus transfer operation. Therefore, the data would pass on the bus at least two separate times. In 5 order to speed operations and not require that the microprocessor read the data from the media access controller and then, in a separate operation, write the data to memory, should it be decided that the data is to be stored in memory, in accordance with the present 10 invention, when data is retrieved from the MAC, it is simultaneously written to a storage address in the SDRAM and into the DSP. Then, if the DSP determines that the data is to be saved, the address pointers to the memory are updated to select a next position in the 15 memory for future data. However, if the DSP determines that the data is not to be stored in the memory, the address pointers are not updated, and instead remain set to the start point of the previous write to memory. That way, the next data that is provided from the MAC 20 is written "over" the previous data that was not to be saved.

According to the invention, therefore, data received from the MAC need only pass the bus once, speeding operations.

25 The timing of the data transfer is accomplished by the CPLD via the control lines. A timing chart is illustrated in FIG. 2, wherein representative signals are illustrated.

30 Three signals from the DSP microprocessor are shown:

- Clock 24 (suitably a 60 MHz clock in the illustrated embodiment)
- DSP\_Command 26 (command signal from the DSP  $\mu$ P)
- Trdsp\_Addr 28 (address data supplied by the DSP 35 to select row and column addresses of the SDRAM)

00062600-14X652960

Two SDRAM signals are shown:

- Sdram\_Command 30 (a command signal to direct the SDRAM operations)
  - Row/Col Addr 32 (Row and Column selection data to address the SDRAM)

One signal from the MAC is shown:

- RX\_Data 34 (received data from the MAC FIFO)

10 Referring still to FIG. 2, the timing of operations are controlled by CPLD 22. Therefore, when an indication that data is available in the FIFO of the MAC (for simplicity, that signal is not shown in the timing diagram), the DSP\_Command line is set to ACTIVE  
15 during the last half of clock cycle 1 and the Trdsp\_Addr is set to the ROW addressing location where data is to be written to in the memory, for a duration of one cycle. Shortly thereafter, at the beginning of clock cycle 2, the Sdram\_Command line is set to ACTIVE  
20 and the Row/Col Addr line 32 is set to the ROW data for one cycle. Afterwards, Sdram\_Command is set to NOP until a change at cycle 7. In the middle of clock cycle 4, (2 clock cycles after the end of the ROW data on the Trdsp\_Addr line) the Dsp\_Command is set to READ (indicating a read) and the Trdspp\_Addr is set to carry the column selection COL indicating the column of  
25 memory to be selected in the SDRAM, both signals for 1 clock cycle duration. One half clock cycle later, at the beginning of clock cycle 5, the COL data is asserted on the Row/Col Addr line for 3 clocks. Soon after cycle 6 starts, the MAC RX\_Data will begin on line 34 carrying the first word of data W1, the data W1 remaining until the end of cycle 7. At the start of cycle 7, Sdram\_Command is set to WRITE for one clock.  
30 After Cycle 8 starts, Sdram\_Command is set to NOP until  
35

cycle 14. The RX\_Data line will subsequently carry valid data from the MAC for next words W2, W3, W4, W5, W6 and W7 during the last half of clocks 9-13, respectively. During the last half of clock 11, a STOP 5 command is set on Dsp\_Command line 26. After the start of clock cycle 14, a STOP appears on Sdram\_Command line 30, finishing the write to memory operation.

The timing control described hereinabove is accomplished by the CPLD 22, to provide timing signals 10 and direct data to appear on the respective lines so that the SDRAM is provided the data according to the timing requirements it has, the MAC is able to write its data to the bus according to the timing requirements of the MAC, and the DSP is able to read 15 the data under its timing requirements. Also, addressing, which is not provided by the MAC (since it is a FIFO device), is generated by the DSP and its timing of assertion is controlled by the CPLD. If, after the data transfer operation described herein, the 20 DSP determines that the data is to be kept, then on the next write to the memory, the ROW and COLUMN addressing would be advanced to the next position in memory for storing data. However, if the data that had been written is not to be kept, then the next write 25 operation will employ the same ROW and COLUMN addressing as the previous write, so that the previous data written to the SDRAM is discarded, as a result of being written over with new data.

The CPLD makes the decision of whether to perform 30 the control operations to govern transfer of data from the MAC based on an address range to which the DSP makes read accesses. If the address is in a designated range, the data transfer as above is performed.

Therefore, in accordance with the invention, two 35 or more destination devices are able to receive data

00000000000000000000000000000000

from a single source, substantially simultaneously. The devices may be dissimilar, such as a FIFO device not having an addressing scheme and memory or processor devices that do employ addressing. Further, while the 5 bus cycles performed by the DSP, as the master device are read cycles, the SDRAM is operating as if performing write cycles. Transfer of the data from the MAC to both SDRAM and the DSP is thereby accomplished with a single bus transfer.

10 The system is preferably embodied in a network test instrument, and enables monitoring and processing of network data received through the MAC. Such received data is suitably analyzed and processed by the DSP to provide information and analysis of network 15 operations.

While a preferred embodiment of the present invention has been shown and described, it will be apparent to those skilled in the art that many changes and modifications may be made without departing from 20 the invention in its broader aspects. The appended claims are therefore intended to cover all such changes and modifications as fall within the true spirit and scope of the invention.

25

30

35